package com.coder.algorithm.sort;


/**
 * 选择排序
 * <p>
 * 选出最小值放到 i 的位置
 *
 * @author yuhushuan
 * @date 2020/6/6 22:06
 */
public class SelectionSort implements Sort {

    public SelectionSort() {
        System.out.println("选择排序");
    }

    @Override
    public void sort(int[] array) {
        if (array == null || array.length == 0) {
            return;
        }
        for (int i = 0; i < array.length - 1; i++) {
            int minIndex = i;
            for (int j = i + 1; j < array.length; j++) {
                // 找到最小的数
                if (array[j] < array[minIndex]) {
                    // 将最小数的索引保存
                    minIndex = j;
                }
            }
            // 将最小的数和 i 位置的值交换
            int temp = array[minIndex];
            array[minIndex] = array[i];
            array[i] = temp;
        }
    }
}
